/**
描述
  有一种技巧可以对数据进行加密，它使用一个单词作为它的密匙。下面是它的工作原理：首先，选择一个单词作为密匙，如TRAILBLAZERS。
  如果单词中包含有重复的字母，
  只保留第1个，将所得结果作为新字母表开头，并将新建立的字母表中未出现的字母按照正常字母表顺序加入新字母表。如下所示：
  A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
  T R A I L B Z E S C D F G H J K M N O P Q U V W X Y (实际需建立小写字母的字母表，此字母表仅为方便演示）
  上面其他用字母表中剩余的字母填充完整。在对信息进行加密时，信息中的每个字母被固定于顶上那行，
  并用下面那行的对应字母一一取代原文的字母(字母字符的大小写状态应该保留)。因此，使用这个密匙， 
  Attack AT DAWN (黎明时攻击)就会被加密为Tpptad TP ITVH。
  请实现下述接口，通过指定的密匙和明文得到密文。

  数据范围：1 \le n \le 100 \1≤n≤100  ，保证输入的字符串中仅包含小写字母

  输入描述：
    先输入key和要加密的字符串

  输出描述：
    返回加密后的字符串

  输入：
    nihao
    ni
  输出：
    le
*/
const readline = require('readline')
const rl = readline.createInterface({
  input:process.stdin,
  output:process.stdout
})

function transform(inputArr) {
  let prevDict = []
  let prevStr = inputArr[0]
  let afterStr = inputArr[1]
  let resArr = []
  // 生成 26 个字母表
  for(let i = 0; i < 26; i++) {
    prevDict.push(String.fromCharCode(97 + i))
  }
  // 输入 字符串 去重
  prevStr = Array.from(new Set(prevStr.split('')))
  // 从字母表里面去掉输入的的字符
  prevStr.forEach((prevItem) => {
    // 找到字母表中的位置，删掉 通过 字符找到位置 会有 bug
    prevDict.splice(prevDict.findIndex((key) => { return key === prevItem }), 1)
    // prevDict.splice(prevItem.charCodeAt() - 97, 1)
  })
  // 把去重后的字符插入到前面
  prevStr.reverse().forEach((item) => {
    prevDict.unshift(item)
  })
  // 输出加密后字符
  afterStr = afterStr.split('')
  afterStr.forEach((item) => {
    resArr.push(prevDict[item.charCodeAt() - 97])
  })
  console.log(resArr.join(''))
}

// 本地测试
let inputArr = []
// transform(inputArr)

// 提交测试
rl.on('line', (line) => {
  if (line) {
    inputArr.push(line)
    if (inputArr.length === 2) {
      // 处理接收
      transform(inputArr)
    }
  }
})